// 登录流程
/*
1.收集表单数据
2.前端验证
  1）验证用户信息（账号和密码）是否正确
  2）前端验证不通过就提示用户，不需要发请求给后端
  3）前端验证通过了，发请求（携带账号，密码）给服务端
3.后端验证
  1）验证用户是否存在
  2）用户不存在直接返回，告诉前端用户不存在
  3）用户存在是否需要验证密码是否正确
  4）密码不正确返回给前端提示密码不正确
  5）密码正确返回给前端数据，提示用户登录成功（会携带用户的基本信息）
  */
import request from "../../utils/request"
Page({

    /**
     * 页面的初始数据
     */
    data: {
        phone: '',
        password: ''
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function(options) {

    },

    //表单内容发生改变的回调
    handleInput(e) {
        let type = e.currentTarget.id;
        // console.log(type,e.detail.value);
        this.setData({
            [type]: e.detail.value
        })
    },

    async login() {
        let { phone, password } = this.data;



        if (!phone) {
            wx.showToast({
                title: '号码不能为空',
                icon: 'error'
            })
            return
        }
        let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/;
        if (!phoneReg.test(phone)) {
            wx.showToast({
                title: '手机号格式错误',
            })
            return
        }

        if (!password) {
            wx.showToast({
                title: '密码不能为空',
                icon: 'error'
            })
            return
        }

        //后端验证
        let result = await request('/login/cellphone', { phone, password, isLogin: true })
        if (result.code === 200) {
            wx.showToast({
                title: '登录成功',
                icon: 'none'
            })

            //将用户的信息存储到本地
            wx.setStorageSync('userInfo', JSON.stringify(result.profile))
            wx.reLaunch({
                url: '/pages/personal/personal',
            })
        } else if (result === 400) {
            wx.showToast({
                title: '手机号错误',
                icon: 'error'
            })
        } else if (result === 502) {
            wx.showToast({
                title: '密码错误',
                icon: 'error'
            })
        } else {
            wx.showToast({
                title: '登录失败',
                icon: 'error'
            })
        }
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function() {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function() {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function() {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function() {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function() {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function() {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function() {

    }
})